- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 33.2k
          gh-124375: Avoid calling _PyMem_ProcessDelayed on other thread states
          #124459
        
          New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
  
    gh-124375: Avoid calling _PyMem_ProcessDelayed on other thread states
  
  #124459
              Conversation
…d states This fixes a crash when running the PyO3 test suite on the free-threaded build. The `qsbr` field is initialized after the `PyThreadState` is added to the interpreter's linked list -- it might still be NULL. Instead, we "steal" the queue of to-be-freed memory blocks. This is always initialized (possibly empty) and protected by the stop the world pause.
| I spent a while trying to get a unit test to reproduce the issue without success. I think the period between when  Lines 1589 to 1600 in 17b3bc9 
 | 
| 🤖 New build scheduled with the buildbot fleet by @colesbury for commit bc567fc 🤖 If you want to schedule another build, you need to add the 🔨 test-with-refleak-buildbots label again. | 
| cc @ngoldbaum | 
| Thanks for this! I'll try to test this with PyO3 tomorrow morning. | 
| Thankfully it seems the 3.14 ABI hasn't yet diverged enough from 3.13 that it's painful to test this with PyO3. It looks like this does fix the segfault - I'm completely unable to trigger it on this PR branch and I can trigger it very quickly with the same test approaches (looping on  | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM!
| Thanks @colesbury for the PR 🌮🎉.. I'm working now to backport this PR to: 3.13. | 
…d states (pythonGH-124459) This fixes a crash when running the PyO3 test suite on the free-threaded build. The `qsbr` field is initialized after the `PyThreadState` is added to the interpreter's linked list -- it might still be NULL. Instead, we "steal" the queue of to-be-freed memory blocks. This is always initialized (possibly empty) and protected by the stop the world pause. (cherry picked from commit 54c6fcb) Co-authored-by: Sam Gross <[email protected]>
| GH-125540 is a backport of this pull request to the 3.13 branch. | 
…ad states (GH-124459) (#125540) This fixes a crash when running the PyO3 test suite on the free-threaded build. The `qsbr` field is initialized after the `PyThreadState` is added to the interpreter's linked list -- it might still be NULL. Instead, we "steal" the queue of to-be-freed memory blocks. This is always initialized (possibly empty) and protected by the stop the world pause. (cherry picked from commit 54c6fcb) Co-authored-by: Sam Gross <[email protected]>
This fixes a crash when running the PyO3 test suite on the free-threaded build. The
qsbrfield is initialized after thePyThreadStateis added to the interpreter's linked list -- it might still be NULL.Instead, we "steal" the queue of to-be-freed memory blocks. This is always initialized (possibly empty) and protected by the stop the world pause.